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iost on which an object resides, and the methods can be invoked by any of the terminals or host computers. Updating the objects 
s aoooxnplished by invoking the relevant method on eadi of the nodes wherein the object resides. The distributed object-based 
transaction system is particulariy useful in the implementation of an auction system for remotely situated bidders utilizins inter- 
active television. 
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INTERACTIVE TRANSACTION PROCESSING SYSTEM 
TECHNICAL FIELD 

This invention relates to th^ art of data processing and the 
combination of data processing with video displays of items related 
5 to the data. In the ultimate preferred embodiment, the invention 
is an auction system for remotely situated bidders conducted 
utilizing interactive television. 

BACKGROUND 

The invention is an interactive transaction processing system 
10 and data processing method. The fundamental system Is a 
distributed object-abased transaction system having a vide range of 
potential uses. This distributed object-based transaction system 
has particular utility in the Implementation of an interactive 
televised auction In which remote subscribers bid in competition 
15 with the live auction in the saleroom. Thus, disclosure of the 
invention will be facilitated by first providing a basic 
appreciation of the operation of an auction. 

An auction normally proceeds xinder the control of an 
auctioneer. An item to be auctioned (sold) is displayed, and the 
20 auctioneer asks for a "bid** for the item. The auctioneer can set 
an opening bid price. The auctioneer invites further bids without 
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specifying the next price. The auctioneer states the price when 
accepting the next bid, using an increment judged as reasonable 
given the number of bidders participating. Each of the bidders 
typically has a "paddle", having the bidder's number on it, which 
3 is held up to signal to the auctioneer that the bidder wishes to 
bid. The auctioneer usually accepts the bid of the first bidder to 
hold up his paddle and states the new price. The number on the 
paddle of the bidder whose bid has been accepted is recorded by the 
auctioneer or his cleric. 

10 saleroom etiquette dictates that if the auctioneer senses that 

two bidders are coiroeting for the item being sold, he_ should 
conduct a "ping-pong" auction between these two bidders. A ping- 
pong auction is a process whereby the auctioneer ignores bids by 
bidders other than the chosen two bidders competing for the item. 

15 When one of the ping-pong bidders drops out, e.g., by failing to 
make a bid, the auctioneer will then accept bids from ot^er 

bidders. ^ 

The system of the invention is designed to allow an auction in 
accordance with this process to be conducted at a plurality of 
20 remote sites. In general, terms used in the art of auctions will 
be used to describe the invention, and the bidders at the remote 
sites will be referred to as "subscribers". It will be 
appreciated, however, that the invention is equally applicable to 
a variety of operations other than auctions. 
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SUMHARY OF THE INVENTION 
A- Dlstrj bulged obiect-based Data Processing 

In accordance with the invention, a distributed object-based 
data processing program provides a system for handling a broad 
range of transactions and is specifically adapted to conduct an 
auction in the preferred embodiment. In accordance with the 
technique known as object-oriented design, the distributed object- 
based data processing program comprises "methods", "objects**, and 
''classes'* . 

An "object" is a data element, the specific definition of 
which depends upon the desired transaction or other operation. In 
the auction system which will be described in detail below, an 
example of an object is the "bid display." This is a list of 
identifications of the first ten bidders whose bids were received 
by the host computer in order of receipt of the bids. 

A "method" is a set of instructions which are provided to \he 
host computer to tell the computer what processes are to be 
performed on the object. For example, when a bid is received, the 
method "update bid display" is invoked which adds the 
identification of a bidder (another object) to the bid display or 
cancels a bid. 

A "class" is a group of related methods, or routines. For 
example, the "user display class" includes the "add user" snd 
"update user" methods. Classes can be arranged in a structure 
where one class "inherits" methods from another class (termed its 
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"superclass*") • The ultimate "ancestor** class is the *'root** class, 
which contains the most generally applicable methods. The methods 
are grouped into classes to maximize efficiency, minimize the 
impact of stibseguent design chamges and promote reusability of 
code. Also, the bulk of the source code is reduced since terms 
common to the grouped methods do not have to be redefined for each 
of the related methods. 

The typical instruction to the computer, which cam be 
prograuBimed in any of a variety of languages is: ** Perform method B 
on object A**. This would cause the computer first to find the 
Class of object A by &^&^chlrig & table of classes « Then-, — it 
searches the method table of that particular class to confirm that 
method B is indeed a part of that class. If the computer cannot 
find the particular method in the given class, it searches its 
superclass. The computer then invokes the particular method by 
calling a siibroutine identified by the method and performing ^e 
steps which comprise the method. 

After the particular method has been performed on the object, 
the system updates the value of that object at all nodes in which 
the particular object resides by invoking the same method at those 
nodes. Thus, if the object ""bid display** resides on several 
workstations and the host, the new value of the **bid display** 
object resulting from the completion of an invoked method relating 
to that object will be propagated to all of the nodes by the update 
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process which invokes ^e same method at each of the remaining 
nodes having the "bid display** object* 

The distributed object-based transaction system of the 
invention integrates an application which is divided into several 
processes and mnning on several machines. For example, an 
application may be terminal-based ^d intended for implementation 
on a single host computer, or it may be implemented on multiple 
workstations connected to a variety of other devices. In the 
auction example described below, personal computers have programs 
capable of implementing individual methods relating to the objects 

on -tJ>.«.parfeJe«1 »ru computer. The jnyok lng _pf^jB^ 

method, which inherently changes the value of an object, is always 
automatically commiinicated to the other workstations and the host 
computer having that object by the process of updating whereby that 
method in also invoked at all nodes having that object. Thus, the 
distributed object-based transaction system provides a unii^orm 
mechanism for interaction between application components while 
allowing each platfo» to contribute maximum functionality. 

Remote procedure call mechanisms are known and give the 
programmer the ability to call a subroutine in the normal way but 
have it execute in another process that could be located in another 
machine. To the programmer, the result appears in exactly the same 
as if the subroutine had been part of his program and had been 
executed in the same process. 
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The remo'te procedure call mechanism used in tha system of the 
invention, as well as that ot other systems, such as Sun's RPC, 
employs a so-called 'stub* routine which takes the place of the 
real routine in the caller *s code. The stub routine then 
communicates with the remote process and passes the necessary 
information to it so that the correct routine is invoked in the 
remote process. The remote process will then return any results of 
the subroutine call back to the stub routine, which will be waiting 
for the reply. The stub routine then unpacks the returned 
information and places it into the proper variables. The stub 
rouSne^Sen returns contarol to the calling routine and executicSft 
continues as normal. 

The distributed object-based transaction system of the 
invention implements a remote procedtire call mecheuiism emd routes 
requests and responses across external networks and internal inter- 
process communications structures (such as pipes and queues) . ^e 
system can cope with multiple paths between two nodes and chooses 
the most efficient rqute available. 

The distributed object-based transaction system allows the 
combination of an advanced, general purpose application 
architecture with specific support for host computer features. 

By permitting any node (object location) to be either a client 
or a server, the distributed object-based transaction system 
transcends fixed client-server roles for networked computers. In 
the traditional system, a server offers a range of services and the 
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client accesses ^ose services. In distributed object-based 

transaction systea of the invention, the server has a range of 
objects, and the client is one who accesses those objects. Any of 
the workstations may be a client with respect to some objects as 
well as a server with respect to other objects. This allows 
workstations, for instance, to be informed of dynamically changing 
information as well to initiate their own transactions. 

The distributed object«based transaction system disclosed 
herein has the further advantage that all interactions between 
nodes on the network are based on a single model. The model 
^follows tj&9^objectrorient^ has the advantage of lojpaX 

transparency to the clients in that the client need only identify 
the data object in a call and not the servers associated with that 
object. For example, a read only recpiest will be directed only to 
the server nearest the client, whereas an update would be 
propagated to all locations of the object. ^ 

A basic feature of the distributed object-based transaction 
system of the invention is that the data can be replicated because 
the objects can reside in multiple nodes. In the traditional 
system, the host is generally the server because it contains the 
database. In contrast, the distributed object-based transaction 
system allows each of the workstations to have a database related 
to the objects residing on that workstation. The system ensures 
consistency between multiple copies of the same data by routing 
update requests to all relevant servers for a given object. For 
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example. If a number of workstations display the value of a 
particular data object which also resides on the host, the system 
will Invoke methods in each of the involved workstations to cause 
all of the values to be the same in all workstations concerned. 
There is, thus, no requirement to explicitly code for the 
distribution of the data because the system automatically updates 
the value of the object at all nodes wherein that object is 
located* 

Transaction management, like shared-memory and concurrent 
processing support, is a specific feature of the Stratus machine, 
whi<i:h i& Ui« piT^fterr^d hcst ccsp'^tsr. «M7-» «™^lv?Jent_f«r.llJt.^i>L«^ 
exist in a few other environments the distributed object-based 
system of the invention manages the Stratus version of them. 
Transaction protection ensixres that every transaction will either 
complete successfully or be fully "backed-out", i.e., leave no 
trace that it ever executed. This featxire is vital for transact*ion 
procession systems and is extremely complex to emulate if not 
available. 

Without transaction protection, a database can become 
inconsistent if 1) two transactions interfere with each other, e.g. 
by updating the same record or 2) a transaction fails dtiring 
execution leaving some updates performed but not others. A 
transaction protection system will ensure that t./o transactions -do 
not interfere with each other and that, if one does not complete, 
it is fully backed-out. 
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The prograsuner normally has call sxibroutines to Indicate 
the start and end of transactions. Ending a transaction normally 
is called * committing* because at this point the changes made take 
effect apparently instantaneously and cannot thereafter be undone. 
In the transaction, the programmer must check the status of every 
file operation to determine whether the transaction can proceed or 
whether the transaction protection system has detected a conflict. 
If a problem is detected, the programmer must abort the 
transaction, i.e. end it abnormally. Ideally, because conflicts 
can arise in the normal course of events, the programmer should 
attempt to execute the fMVtire^^ 

of the conflict (another transaction) will finish eventually. 

Instead of the programmer having to code for these functions, 
the distributed object-based transaction system of the invention 
takes over the management of transactions. Because a transaction 
in accordance with the system of the invention corresponds tte a 
method, the system will start the transaction before calling the 
method code and, when the method finishes, the system can commit. 
The system also has all the information at hand to restart 
transactions which fail. It does this by offering the progreunmer 
equivalents to all the file operation subroutines. These 
equivalents call the real file subroutine but check the status of 
the result. If they detect a conflict, the method is aborted at 
that point and control j tamps back to the system which can call the 
transaction again automatically. 
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Another feature of the system of the Invention Is its port 
pool management. Before the data of a file can be accessed in a 
program, a port must be "opened** to that file* There is an "open** 
operating system routine which locates the file by neu&e and creates 
a port through which that program can access it. Thereafter, the 
file is accessed by the given port cumber, not by its name. In the 
open call, the programmer specifies what kind of access is 
required, such as input or update, indexed or sequential. The port 
also remembers the program's current position in the file, so that 
calls can be made to read successive records or update the current 
record.' ^ — ^^a^-^-^.^.... 

A batch program will open ports, perform file operations and 
then close them again. . With an on-*line, real-time system, ports 
cannot be opened for each transaction eis this would create an 
unacceptable overhead. Instead, ports are opened once when the 
system starts and stay open while the system is up. ^ 

Because the system of the invention allows methods to be 
called from anywhere, including from other methods, a situation can 
arise where a method uses the saune port as the method calling it. 
If, in using the port, the method altered the current position in 
the file then the calling method would lose its position. To avoid 
this type of interference the system ensures that methods called by 
other methods in the same process use different ports. It does 
this by maintaining a pool of ports which were opened when the 
system started. As many ports are opened as are likely to be 
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needed in the course of processing. Before a aethod can access a 
file it calls a system port allocation routine in the same way that 
it would have called the "open" routine. The port allocation 
routine finds a pre-opened port satisfying the type of access asked 
for and marks it as in use by this particular method. When the 
method completes, the system automatically marks the port free 
again (i.e., de-allocates it). If another method is called within 
the first method, then a different port will be allocated to it. 
The mapping of pooled ports to real ports is performed by the same 
substitute file operation subroutines that are responsible for 
detecting -transaction prstsstisr* csnflicts outlined abov** — - — 

B. Distributed Oblect-basad Data Pgoeessina A p plied to a Televised 
Auction System 

Application of a distributed object-based data processing 
system to a televised auction system in accordance with a preferred 
embodiment reqpiires the following objects. The object's nodes 
(locations) and class are set forth adjacent to each of the objects 
in the table. 



1 OBJECT NAME 


MODES 


CLASS 1 


Obdic 


Host 


Obdic 


Sessions 


Host 


Session 


Users 


Host 


User 


1 Auctions 


Host 


Auction 


Currencies 


Host 


Currency 


Sale 


Host 


Sale 
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1 OBJECT NAME 


NODES 


CIASS 


Sale Number 


Hos't and 
Controller * s 
workstation 


Root 




Board Operator's 
Wor)cstation, and 
Auctioneer * s 
Display ^ 


Bidlevel 


1 currency board 


Host, Television 
Display, and 
Saleroom Display 


Root 


Currenl^lo^ 


Host, 
Controller * s 
Workstation, 
Currency Board 

jQ^erator-ts . * - - 

Auctioneer's 
Display, Television 
Display, and 
Saleroom Display 


Root 1 


Bidding Flag 


Host, 

v» wn WX X BX 9 

Workstation , and 
Currency Board 
Operator's 
Workstation 


Root 


Ping-pong flag 


Host and 
Controller's 
Workstation 


Root 




Controller's 
Workstation, and 
Auctioneer's 
Display 


Root 1 


1 Leadincr bidder 


Host, 
Controller ' s 
Workstation , and 
Auctioneer ' s 
Display 


Root 
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1 OBJECT NAME 


NODES 


CIASS 




1 Last accepted 
bidder 




Host, 
Controller's 
Workstation , 
Auctioneer ' s 
Display, Television 
Display, and 


Root 






nosw ana ^ 
Controller's 
Workstation 


oxaaxspxay 








T .^\f*t 4 ^ 

xA^xnuoo 




1 Nextlots 


Host and 
Controller's 
Workstation 


Root 




Bids 


Host 


Bid ^ 





Exemplary objects as set forth above are defined as follows: 



"Obdic" is the object dictionary and contains the names 
of all objects, their locations, and a routing taJdle which 
tells the computer the location of all objects and how to find 
each of the locations. This object is a basic part of vthe 
distributed object*based data processing system. 

"Sessions" is a list of log- in times for each user, and 
where that user is located (e.g., Helsinki) for each session. 

"Users" is a list of those entitled to use the system. 
These include paid subscribers to the system and the staff of 
the concern operating the system. 

"Auctions" is information atbout the items to >e 
auctioned, such as a list of the lots being sold. 
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"Currencies* is a list of the various currencies to be 
displayed and the exchange rates. 

"Sale** is a set of details of the current sale which is 
in progress. The information in this object may be obtained 
from the "auctions" object. 

"Sale number" is the number assigned to the current sale. 
A blank indicates that no auction is currently in progress. 

»Bid level" is the amoiint of the current bid. 

"Currency board" is a translation of the bid level into 
the various ctirrencies contained in the "Currencies" object. 

"Current lot" ^s the lot nximber and misceliaheous "detai'iW" 
of the current lot being sold. 

"Bidding flag" is an indication whether bidding is in 
progress (i.e., the auction is not between two lots). 

"Ping-pong flag" is an indication whether a ping-pong 
auction procedure is in progress. 

"Number of bidders" is the number of bidders which bid 
through the system in the current round. ,This is obtained by 
instructing the computer to accumulate the niunber of bid 
signals received in any given roxind. 

"Leading bidder" is the identification of the user whose 
bid signal was first received by the computer (including the 
first bidder in a ping-pong) or was "promoted" from the bid 
display by the controller. 
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"Las^ accepted bidder" is the identification of the 
bidder whose bid was accepted by the auctioneer in the last 
bidding round. 

"Bid display" is a list of the bidders in the order in 
which the bids were received by the computer. This list is 
preferably limited in size to \the top ten bidders. 

"Log in table" is a table of users which have logged in 
for the cuzxent session. 

"Next lots" is a description of several subsequent lots 
to be auctioned. 

^ !lBiA«?L_i>L., m^tf^hlBr jr^f^ bids . and routines to prQceas_^ii 

incoming bid. 

Exemplary classes for computer implementation of the televised 
auction system described herein are as follows: 

"Session" class contains methods for determining the 
period a user is logged onto the system. This includes st^ps 
for determining log-in and log-out of a user. 

"User" class contains methods which perform operations on 
the user file or another file such as a group file. These 
operations are, for example, adding, deleting, or updating a 
user (subscriber) , and getting a user file for other 
operations. 

"Currency" class contains methods for adding, deleting 
and changing currencies and currency exchange rates and for 
effecting exchange rate calculations. 
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"Auction" class contains methods for adding , deleting, 
and getting both an auction and a lot and for indicating when 
the hammer has fallen (as when an auction is terminated by 
acceptance of a final bid) and the next lot is to be 
auctioned* 

"Date" class determines \ the current date and performs 
date manipulations. 

"Sale" class contains methods to start an auction by 
initializing relevant objects to a useful state. For example, 
the bid display object must be set to zero or blank values, 
""^''•"^ imd "the 'm^Eer^t^^DiSrcL&s ob j ect fiio^ sfe^ L; to ; Tiifes-^ 

methods may be invoked by pressing a "start auction" button on 
the Controller's Workstation. 

"Bid display" class contains methods to control the bid 
display, which is the display of the top ten bidders. These 
methods also update the bid display by adding or canceliAg a 
bid. 

"Bid level" class contains methods to set a new bid 
level. For example, when the auctioneer accepts a bid, he 
states the price of the bid, and the currency operator 
provides an input specifying that level and invoking a method 
to update the bid level object. 

"Bid" class contains a bid method, which updates the bid 
display object and the ntimber of bidders objeci:, and a bid 
cancel method, which removes bidders from the bid display. 
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replaces the canceled bidder, and updates the nunber of 
bidders. 

"Login table" class maintains a list of the users, the 
log in table object, who have logged on the system, 
5 In the preferred embodiment, the fxinctions described above are 

performed by a general piurpose computer, such that sold under the 
tradenzune "Stratus", and by personal computers, such as those using 
the Microsoft DOS operating system. The personal computers are 
programmed to advise the general pxirpose computer that they manage 
10 a copy of a particular object auid are to be informed of changes to 
it (eVg.^ they will receive ••set"^equest^ 
value) • 

BRIEF DESCRIPTION OF THE DRAWINGS 
Figure 1 is a schema-tie diagram of the preferred hardware for 
15 implementation of an interactive, televised auction. ^ 
Figure 2 is an illustration of the auctioneer's display. 
Figure 3 is an illustration of the controller's display. 
Figure 4 is an illustration of a currency controller's 
display, 

20 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMEMT 
Figure 1 illustrates a combination of computers and 
communication elements which may be used to conduct a televised 
auction, or other interactive event. A host computer 2 is 
progreunmed with the distributed object-based transaction system 
described eOjove and which has been tailored for a televised 
auction. The host computer 2 receives input from a subscriber by 
receiving signals generated at a subscriber terminal 4. The system 
is capable of receiving input from a large ntunber of subscribers, 
but a single subscriber has been sho%m in the figures for 
illustration . In the ordinary arxang®aenw, xhti subscribers axte. 
located at large distances from each other 2md from the location of 
the live auction and aure, thus, large distances from the host 
computer. The preferred data connection between the subscriber 
terminal and the host computer is a telephone line, which is 
connected to a packet-switching network such as 6. 

The subscriber also has a television 8 which receives 
broadcast signals by way of a satellite network 10, or other 
broadcast system. The screen of the subscriber television 10 is 
preferably divided into foiir areas. The first area 12 contains a 
number (the "paddle" niunber) identifying the bidder whose bid was 
accepted in the last round and the location of that bidder. This 
is preferably a display of the "last accepted bidder" object. Area 
14 of the subscriber's television screen contains the amount of the 
last accepted bid in the selected currencies. This may be a 
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display of "currency board" object. Area 16 contains a video 
display of the article being auctioned, and area 18 contains a 
video display of the auctioneer. 

The areas 12, 14, 16, and 18 are generated by a television 
mixer 20 which combines signals from the host computer which 
produce the displays of the currency board and last accepted bidder 
objects with video signals from one or more television cameras (not 
shown) in the auction room directed at the article being auctioned 
and the auctioneer. The display of objects generated by the host 
computer may be assembled by a television display generator 22 
-trhich-Gupplics signals t?? ti^e. ^^If^v^.F^r^r? yn^r^^r:. 2(X, ^ ^ - .... 

Several other display devices are provided for use by 
personnel associated with the auction. These are the auctioneer's 
display 24, the display on the currency converter workstation 26, 
and the display on the controllers *s workstation 28. Each of these 
is connected to the host computer for supply by the host with 
signals representing the selected objects required by these 
articles. The preferred connection between the host and the 
workstations is by way of an X25 switch 30. 

The auctioneer's display only receives signals from which it 
generates a display. An example of the auctioneer's display is 
shown in figure 2 wherein the nxamber of the lot being sold is 
displayed at 32, the last accepted bid level at 34, the last 
accepted bidder at 36, and the number of bidders at 38. This 
display may be on a video screen located near the auctioneer such 
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^a-t it is. easily seen and is preferably projected on a semi- 
transparent screen located such that the auctioneer can view 
simultaneously both the bidders in the salerooa and the display. 

The currency converter workstation 26 and the operator's 
worlcstation 28 are preferably personal computers capaible of 
providing input to the system, including the host computer 2, 
relating to their fxinctions in the conduct of the auction. In one 
embodiment, two personal computers are supplied with programs such 
that either may sexve as the currency converter worlcstation or the 
operator's workstation. Alternatively, these workstations may be 
"provided with^proe^ thia selected fuhctioh. i Thfe 

screens are preferably touch sensitive whereby touching a selected 
display feature invokes an appropriate method of the distributed 
object-based transaction system. 

Figure 3 illustrates the display associated with the 
controller's workstation 28. This display contains the Ast 
accepted bidder at 40, the leading bidder at 42, the number of 
bidders at 44, the top ten bidders at 46, the number of the current 
sale at 48, and the lot number at 50. Touching one of the buttons 
46 causes that bidder to be promoted to the leading bidder at 42, 
and touching the leading bidder display at 42 causes that bidder's 
bid to be accepted. Acceptance of a bid identifies that bidder as 
the "last accepted bidder". 

A "ping-pong" bat 52 indicates that a ping-pong procedure is 
being conducted by the auctioneer, and a button 54 permits the 
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operator to remove the ping^-pong symbol when the ping-pong is 
terminated. A "hammer fallen** button 56 allows the operator to 
indicate that the auctioneer has completed the sale of a lot, and 
touching this button causes the host computer to invoke the 
appropriate method to record such and to make any necessary updates 
of relevant objects. 

Figure 4 illustrates the display on the currency board 
operator's workstation. This display shows the last accepted bid 
level at 58 and a series (in this example, ten) of pre-set 
increments above the last accepted bid at 60. Buttons 62 adjacent 
~^ehch^S¥* the Uricf @d'€^^ alldw xia^ iiiuiL euen cb; tirsmselv^es*^^ 

be adjusted within the preset increment in case the auctioneer 
calls for a bid within the pre-set increments. A button 70 allows 
the currency board operator to set initial values. Touching this 
causes a keypad display to be superimposed on the display of figure 
4 whereby the operator may key in the initial values. Box^ 72 
displays the increment between the values shown in boxes 60, which 
in the illustration is £100. The current lot is displayed at 74. 

Buttons 76 and 78 are provided for the case where the 
auctioneer calls for a price wholly outside the scale of the 
display. Button 76 causes the entire display to be shifted do%m by 
a preset amount, while button 78 causes the display to be shifted 
upward. 

Button 80 allows the operator to exit from the display. 
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As the auction proceeds, the auctioneer states the price of 
the bid based inter Alia upon the number of bidders. The currency 
operator enters this price by touching the button 60 having that 
price. The increment and number of prices displayed are designed 
to ensure that in the majority of cases, one of the areas 60 will 
show the price called for by the auctioneer. If the correct price 
is not displayed already, however, the cuxxency operator uses the 
buttons 62, 76 or 78 to adjust the display until the correct price 
is displayed in one of the boxes 60. That price is then selected 
by the operator's touching that box, and this invokes methods to 
update the "last accepted bid" object^Sltil^^^t^ 

The subscriber's terminal 4 allows the siibscriber to interact 
with the auction being conducted in the saleroom and viewed on 
television 8. The terminal 4 may be of the type manufactured by 
Verifone and provides a slot for receiving an identification card 
(not shown) which has been provided to the subscriber toy .the 
operator of the system after appropriate credit Investigations, or 
the like. 19hen a subscriber wishes to participate In an auction, 
the card Is "wiped" through the slot, and the terminal 4 reads the 
subscriber's Information from the ceurd. The sxibscrlber Is prompted 
by messages on display screen 66 to enter an Identification number 
by way of key pad 68. The Identification number is verified by an 
appropriate method in the host computer after which the subscriber 
is permitted to participate in the auction. 
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The subscriber's terminal includes buttons or other input 
devices for activation by the subscriber to allow the subscriber to 
signal the host computer that he wishes to bid or cancel a bid. For 
example, the s\ibscriber*s terminal has a ''bid" button which signals 
5 the host computer that the subscriber has bid on the article being 
auctioned. 

An auction utilizing the above described methods and devices 
would proceed as follows. 

The controller would sign on at the controller's workstation, 
10 and the currency board operator would sign on at the currency board 
-operator's —workstation .-^^-^ host ccsputcr — then pcrfsrms- 

initializing methods which prepare the system to conduct the 
auction or perform system maintenance functions by updating any of 
the files, such as "user", "auctions", or the like. 
15 A user begins by wiping the card issued by the auction 

operator in the slot on the subscriber's terminal and entering ^e 
assigned password. The terminal generates the "pin_login" method 
in the "sessions" class, and this method passes the user 
identification from the card and the password which has been 
20 entered by the user to the host for verification. 

The televised auction is begun by the controller's pressing 
the "start auction" button on the controller's workstation when the 
auction in the saleroom is also begxin. This activates the "begin 
sale" method which may be found in the "sale" class. The "next 
25 lot" method is called to set the "current lot" to "1", the number 
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ot bids to zero, and 'the ping<-pong flag to zero. The bid display 
is also initialized and the bidding flag is set to one to allow 
bids to be received. 

When a remote bidder presses the "bid" button on the terminal 
4, the host computer is requested to perform the "bid" method on 
the "bid" object which is this case is the identification of the 
bidder. The host also increases the "number of bidders" by one, 
sets the leading bidder by providing the identification of the bid 
to be received first, and updates the bid display. This process is 
followed for each subsequent bid. 

When a bid is accepted by the auctioneer, the "leading bidder" 
is set and the identification of the bidder whose bid was accepted 
is moved to the "accepted bidder" location on the display such as 
at 42 in the display of figure 3. This is accomplished by the 
controller by his touching the proper one of the buttons 46, if the 
bidder is remote, or the button 43, if the accepted bidder is^ in 
the saleroom. The currency operator selects the proper button to 
display the "last accepted bid" level. 

When the auctioneer begins a ping-pong auction, the "ping- 
pong" flag is set by the controller activating a "ping-pong" button 
and identifying the participants of the ping-pong. This causes the 
ping-pong symbol to be displayed on the various displays and 
permits only the peurticipants of the ping-pong to be listed on the 
display as the last accepted bidder or the leading bidder. The 
identifications of the other bidders are placed on the bid display. 
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but none can be a "leading bidder" without the auctioneer first 
terminating the ping-pong. 

When the auctioneer signals that the sale of the lot is 
completed, the "hasmer fallen" method is invoked by the controller 
5 activating a "hzunmer fallen" button. This sets the bidding flag to 
zero, which indicates that no bids will be accepted by the host 
computer. 

The steps followed by the distributed 
oDjecr-based transaction system are as follows. Activation of an 

10 input device, such as by touching a touch sensitive screen causes 
a "request" to be generated! • That recjuest comprises a method and 
an object and is in essence a statement to the computer to perform 
the stated method on the stated object. The computer first looks 
at the object table, such as one contained in the "obdic" object 

15 described above with respect to the Interactive auction system. 
This table allows the computer to identify the devices on which ^e 
object resides, such as the host computer and one of the 
workstations. As noted above, it is a feature of the distributed 
object-abased transaction system that the objects may reside on one 

20 or more separate devices. The computer determines the best route 
to the various locations of the object from the table and sends the 
instruction to all appropriate nodes where the object resides. The 
method is then performed on the object at all of the nodes on which 
the object resides. A reply is then sent if the selected method or 

25 original recjuest called for a reply. 
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vill be appreciated that a unlqpie transaction system has 
been described. Modifications within the scope of the appended 
claims vill be apparent to those of skill in the art. 
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We Clain: 

1. An interactive systea comprising: 

host computer means for performing data operations; 

a plurality of workstation terminal means connected to said 
host computer for displaying data from said host computer and for 
providing input to said host computer, 

television network means for transmitting video information to 
a plurality of siibscriber video terminals; and 

a plurality of subscriber data terminal means for supplying 
data to said host computer. 
- 2 . An interactive network according tw elaiu. 1 £\^i:iJhH^ x^ot^pxrl-^kii}^- 
mixing means for supplying said data from said host computer to 
said television network for combination with said video 
information. 

3. An interactive system according to claim 2 wherein said 
television network comprises television signal broadcast means^for 
supplying said video information to said subscriber video terminals 
and said subscriber terminal means comprises telephone transmission 
means for supplying said data from said stibscriber terminal means 
to said host computer. 

4* An interactive system according to claim 3 wherein said video 
information produces an image of an item being sold on each of said 
subscriber video terminals and said data contains information about 
the price of said item. 
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5. An interactive systea according to claim 4 wherein at least 
one of said workstation terminal mecms displays said information 
about the price of said item. 

6. An interactive system according to claim 5 wherein said 
information about the price of said item comprises the last bid for 
said item which has been accepted in an auction. 

7. A method for conducting a transaction comprising 
providing a host computer with data regarding an item, 
providing an input terminal to at least one subscriber for 

transmitting signals to said host computer. 



providing a video terminal for displaying" an Ima of said 
item to said subscriber, 

wherein said signals indicate transaction information with 
respect to said item. 

8. A transaction system comprising a host computer for performing 
data operations, a subscriber terminal for transmitting data from 
a subscriber to said host computer, video means for transmitting an 
image of an item to said subscriber, and a workstation terminal for 
displaying data from said host computer and for transmitting data 
to said host computer. 

9. A method for processing data comprising 
providing a plurality of computing means, 

defining a plurality of objects by allocating memory space in 
said computing means for each of said objects and by naming each of 
said objects. 
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providing at least one method for performing an operation with 
respect to said objects, 

wherein said memory space for at least one of said objects is 
allocated in a plurality of said computing means and said method 
includes the step of updating the value of said object at all 
memory spaces assigned to said qbject upon completion of said 
method. 

10. A method according to claim 9 wherein said objects are related 
to an auction, and said at least one method comprises a plurality 
of methods relating to an auction. 
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